草庐IT

C++ 类 class

全部标签

c++ - 有类(class)的 friend 但不能访问私有(private)成员

友元函数应该可以访问一个类的私有(private)成员吧?那么我在这里做错了什么?我已经将我的.h文件包含在运算符#includeusingnamespacestd;classfun{private:inta;intb;intc;public:fun(inta,intb);voidmy_swap();inta_func();voidprint();friendostream&operator 最佳答案 在这里...ostream&operator你需要ostream&operator(我被这件事折磨了无数次;你的运算符重载的定义与声

c++ - "Template argument for template template parameter must be a class template or type alias template"

templatestructList{};templateclass>structListHelper;templatestructListHelper>{};^/*Error:Templateargumentfortemplatetemplateparametermustbeaclasstemplateortypealiastemplate*/怎么了?我正在使用clang++SVN。 最佳答案 您有一个模板模板参数。您必须传递一个模板作为其参数。您改为将模板实例化作为其参数传递-这是一个具体类,而不是模板(其所有参数均已绑定(bi

c++ - 我们是否需要显式调用分配给 "simple POD classes"的 "placement new"的析构函数?

这里的“简单”是指具有非虚空析构函数或POD类型的类。典型例子:charbuffer[SIZE];T*p=new(buffer)T;...p->~T();//如果我们不在p上调用显式析构函数会怎样?我不认为这是未定义的行为或内存泄漏。重用buffer有什么问题吗? 最佳答案 从技术上讲,假设析构函数不释放在构造期间获取的任何资源,则可能没有必要。但是,考虑到非技术方面——代码的维护和演进——我会坚持最佳实践——构建的东西应该被破坏。要考虑的场景-如果将来某些更改将确定要放入析构函数中的相关代码怎么办?你会记得你怀疑过那种类型的对象的

c++ - 什么是变量的链接和存储说明符?

当有人谈论变量存储类说明符时,他们在谈论什么?他们还经常在同一上下文中谈论变量链接,那是什么? 最佳答案 存储类说明符控制变量的存储和链接。这是两个不同的概念。C为变量指定了以下说明符:auto、extern、register、static。存储存储时间决定了你的变量在内存中的生存时间。存储时长分为静态、自动和动态三种。静态如果您的变量是在文件范围内声明的,或者带有extern或static说明符,它将具有静态存储。只要程序在执行,变量就会一直存在。创建这些变量不会花费执行时间。自动如果变量在函数中声明,但没有extern或stat

c++ - Class vs Struct 仅用于数据?

在这种情况下,使用类而不是结构有什么优势吗?(注意:它只会保存变量,永远不会有函数)classFoo{private:structPos{intx,y,z};public:PosPosition;};对比:structFoo{structPos{intx,y,z}Pos;};类似问题:WhenshouldyouuseaclassvsastructinC++?WhatarethedifferencesbetweenstructandclassinC++?WhenshouldIuseastructinsteadofaclass? 最佳答案

c++ - 为什么gcc/clang要用两个128bit的xmm寄存器来传递一个值?

所以我偶然发现了一些我想了解的东西,因为它让我头疼。我有以下代码:#include#includetypedefunion{struct{floatx,y,z,w;}v;__m128m;}vec;vec__attribute__((noinline))square(veca){vecx={.m=_mm_mul_ps(a.m,a.m)};returnx;}intmain(intargc,char*argv[]){floatf=4.9;veca=(vec){f,f,f,f};vecres=square(a);//?printf("%f%f%f%f\n",res.v.x,res.v.y,re

C++ 错误 : object of abstract class type is not allowed: pure virtual function has no overrider

继承有问题。我不知道我做错了什么。FigureGeometry.h#ifndefFIGUREGEOMETRY#defineFIGUREGEOMETRYstaticconstfloatPI=3.14159f;classFigureGeometry{public:virtualfloatgetArea()const=0;virtualfloatgetPerimeter()const=0;};#endifCircle.h#ifndefCIRCLE#defineCIRCLE#include"FigureGeometry.h"classCircle:publicFigureGeometry{fl

c++ - 前向声明包括,在声明之上包括(ClassFwd.h + Class.h)

在EffectiveC++(第3版)中,ScottMeyers在第31项中建议,类应该在其经典的声明(.h)和定义(.cpp)文件之上有一个前向声明包含文件(fwd.h)不需要完整定义的类可以使用,而不是前向声明自己。我有点看到它的情况,但我真的不认为这是一个可行的选择......它似乎很难维护,相当大材小用而且几乎没有必要。但是,我可以看到它用于模板前向声明,这是相当繁重的。但是对于简单的类?维护起来似乎很痛苦,并且会创建大量几乎空的包含文件,这些文件的用途很小……值得这么麻烦吗?这是一个例子://Class.hclassClass{Class();~Class();};//Clas

c++ - 如何将 C++ vector 传递和访问到 OpenCL 内核?

我是C、C++和OpenCL的新手,目前正在尽最大努力学习它们。这是一个预先存在的C++函数,我试图找出如何使用C或C++绑定(bind)将其移植到OpenCL。#includeusingnamespacestd;classTest{private:doublea;vectorb;vectorc;vector>d;public:doublefoo(longx,doubley){//mathematicaloperations//usingx,y,a,b,c,d//andalsob.size()//tocalculatereturnvaluereturn0.0;}};大体上我的问题是如何

c++ - this->field 和 Class::field 之间的区别?

我想知道C++中的一些东西。承认以下代码:intbar;classFoo{public:Foo();private:intbar;};在我的类(class)中,this->bar和Foo::bar之间有什么区别吗?是否存在无效的情况? 最佳答案 在Foo类中(具体来说)两者之间没有区别,因为bar不是static。Foo::bar被称为成员bar的完全限定名,这种形式在层次结构中可能有多个类型定义一个同名成员。例如,您需要在此处编写Foo::bar:classFoo{public:Foo();protected:intbar;};c